# **UltraScale FPGAs Transceivers Wizard Demo Script**

### Introduction

In this demonstration, you will customize a transceiver and generate and implement its example design.

## **Preparation:**

• Required files: \$us transceiver/demo

• Required hardware: None

• Supporting materials: "UltraScale Architecture Transceivers" module

#### **UltraScale FPGAs Transceivers Wizard**

|   | Action with Description                                                                      | Point of Emphasis and Key Takeaway                                                                               |
|---|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| • | Launch the Vivado Design Suite 2019.1.                                                       |                                                                                                                  |
| • | Click the <b>Create Project</b> link in the Quick Start section of the Getting Started page. | The New Project link in the Getting     Started page allows you to create a     new Vivado Design Suite project. |
| • | Create a new project using the New Project Wizard with the following details:                | By default, the Vivado IDE creates<br>the project name as <i>project_1</i> .                                     |
|   | <ul><li>Project name:<br/>transceiver_demo.xpr</li></ul>                                     |                                                                                                                  |
|   | • Project location: \$us_transceiver/demo                                                    |                                                                                                                  |
|   | <ul> <li>Enable Do not specify the sources at this time.</li> </ul>                          |                                                                                                                  |
|   | • Select the <b>KCU105</b> Board.                                                            |                                                                                                                  |
|   | • Click <b>Finish</b> to create the project.                                                 |                                                                                                                  |
| • | Select <b>IP Catalog</b> under Project<br>Manager in the Flow Navigator.                     | Open the IP catalog.                                                                                             |

| Action with Description                                                                                                                                                               | Point of Emphasis and Key Takeaway                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>In the IP catalog, expand FPGA         Features and Design &gt; IO         Interfaces and double-click         UltraScale FPGAs Transceivers         Wizard.     </li> </ul> | Open the Transceiver Wizard.                                                                                                                                                                     |
| Examine the links under the headline.                                                                                                                                                 | <ul> <li>The GUI offers general information:</li> <li>Link to documentation</li> <li>List of presets</li> <li>IP location on host</li> <li>Switching to default settings</li> </ul>              |
| <ul> <li>Select the IP Symbol tab in the left<br/>frame and explain the graphical view<br/>window.</li> </ul>                                                                         | The GUI offers an IP Symbol graphic that will be updated during configuration.                                                                                                                   |
| <ul> <li>Enable and disable the Show<br/>disabled ports option under the IP<br/>Symbol tab.</li> </ul>                                                                                | Where would you find what the<br>functionality of the ports shown in<br>the diagram are?                                                                                                         |
| <ul> <li>Select the <b>Physical Resources</b> tab in the left frame and review the graphical view window.</li> <li>Use the scroll bar to view all content.</li> </ul>                 | The GUI offers a graphical representation of the physical resources that will be updated during configuration. This includes clocking connectivity.  • What resources are described in this tab? |

|   | Action with Description                                                                    | Point of Emphasis and Key Takeaway                                                                                                                                                                                            |
|---|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Select the <b>Basic</b> tab and observe the configuration options.                         | The Basic tab provides customization options for fundamental transceiver features, including transceiver type, transmitter, and receiver settings. It also provides the ability to select a transceiver configuration preset. |
|   |                                                                                            | <ul><li>What type of presets are available?</li><li>What does the Transceiver type select?</li></ul>                                                                                                                          |
| • | In the System section (Transceiver Configuration Preset), select <b>GTH:CPRI 10 Gb/s</b> . | Transmitter and receiver parameters will be set according to the selected protocol.                                                                                                                                           |
| • | Select any parameter in the Transmitter section and observe the customization options.     | Try a few customization options (alter the user data width).                                                                                                                                                                  |
|   |                                                                                            | <ul> <li>Does this change alter the symbol generated?</li> </ul>                                                                                                                                                              |
|   |                                                                                            | Go to the IP Symbol graphic, which may be updated.                                                                                                                                                                            |
| • | Select the <b>Physical Resources</b> tab and observe the configuration options.            | The Physical Resources tab provides table and graphical interfaces to select specific transceiver channel sites to enable as well as reference clock routing options.                                                         |
|   |                                                                                            | Record the pins used for channel X0Y0. Verify their location in the Pin Planning view later.                                                                                                                                  |

| Action wi                                                         | th Description                                                                                     | Point of Emphasis and Key Takeaway                                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| reference clock<br>bar in the Phys<br>graphical wind<br>settings. | ent channel and cource. Use the scroll sical Resources low to show the new GTHE3_CHANNEL_TREFCLKO. | <ul> <li>Demonstrate channel and clocking assignment.</li> <li>Why does the QPLL0 assignment not change by selecting a different channel?</li> <li>From the physical resources pane record that QPLL0 and QuadX0Y0_clk0 was used by default. Verify their location in the Pin Planning view later.</li> </ul> |
| _                                                                 | <b>ional Features</b> tab<br>me of the options.                                                    | The Optional Features tab provides extensive configuration options for optional or advanced features, if appropriate for the application.                                                                                                                                                                     |
| detection and                                                     | ceiver comma<br>I alignment section.<br>parameters are set.                                        | 8B/10B encoding requires K characters for operation.                                                                                                                                                                                                                                                          |
|                                                                   | ectural Options tab<br>ne configuration                                                            | The Structural Options tab provides location choices for each available helper block and the optional port enablement interface.  • Review the helper blocks.                                                                                                                                                 |
| Select the <b>qpll</b>                                            | nad PLL Ports section. Olock_out port. eate the directory.                                         | <ul> <li>Demonstrate enabling additional ports.</li> <li>Can you verify that this new port was made?</li> <li>Hint: View the IP Symbol pane.</li> </ul>                                                                                                                                                       |
| Name the tran as my_trx.                                          | sceiver IP component                                                                               | Replace the generic component name with a user-specific name.                                                                                                                                                                                                                                                 |
| • Click <b>OK</b> .                                               |                                                                                                    | Generate the core configuration file.                                                                                                                                                                                                                                                                         |

|   | Action with Description                                                                                         | Point of Emphasis and Key Takeaway                                                                                               |
|---|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| • | In the Generate Output Products dialog box, click <b>Generate</b> .                                             | Generate the core files. Synthesis of the core will be performed.                                                                |
|   |                                                                                                                 | What is the purpose of each of these output files?                                                                               |
| • | Observe the design hierarchy in the Sources tab.                                                                | The IP core source file is just the XCI file.                                                                                    |
| • | Review the other tabs as well.                                                                                  | Are there any pin assignments associated with the creation of this core? How can you verify this?                                |
|   |                                                                                                                 | Refer to the IP Sources tab, expand<br>the Synthesis folder, and review the<br>contents of the XDC files.                        |
| • | Review the <b>IP Sources</b> tab.  Observe the different IP products                                            | By default the following IP products are generated:                                                                              |
|   | generated under my_trx.                                                                                         | Instantiation template                                                                                                           |
|   |                                                                                                                 | • Synthesis                                                                                                                      |
|   |                                                                                                                 | Simulation                                                                                                                       |
|   |                                                                                                                 | Change log                                                                                                                       |
|   |                                                                                                                 | • DCP                                                                                                                            |
|   |                                                                                                                 | • Stub                                                                                                                           |
| • | Expand each IP output products folder and observe the different files under them.                               | Explore the generated files.                                                                                                     |
| • | In the Sources window, under Design Sources, right-click my_trx (my_trx.xci) and select Open IP Example Design. | This creates the IP example design<br>that will be stored in a different<br>directory. The original design will be<br>untouched. |

| Action with Description                                                                                                                           | Point of Emphasis and Key Takeaway                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| <ul> <li>In the Open Example Design dialog<br/>box, browse to the<br/>\$us_transceiver/demo directory<br/>to store the example design.</li> </ul> | A new Vivado Design Suite session opens with the IP example design.                                |
| • Click <b>OK</b> .                                                                                                                               |                                                                                                    |
| <ul><li>Observe the design hierarchy.</li><li>Review the other tabs as well.</li></ul>                                                            | The generated example design includes all files for synthesis, simulation, and implementation.     |
|                                                                                                                                                   | The design hierarchy includes the pattern generation and checking blocks.                          |
|                                                                                                                                                   | <ul> <li>Note that my_trx_example_top is the<br/>top-level name for the new project.</li> </ul>    |
|                                                                                                                                                   | How did the pin assignments get made?                                                              |
|                                                                                                                                                   | example_wrapper_inst includes the helper block files for (as specified in the Transceiver Wizard): |
|                                                                                                                                                   | TX user clock                                                                                      |
|                                                                                                                                                   | RX user clock                                                                                      |

### **Summary**

In this demo, you walked through the customization of an UltraScale FPGA transceiver using the Transceiver Wizard. This new version of the wizard supports detailed IP core customization and the use of flexible helper blocks. You also generated an example design.